<!DOCTYPE HTML>
<html>
<!--
https://bugzilla.mozilla.org/show_bug.cgi?id=590353
-->
<head>
  <title>Test for Bug 590353</title>
  <script type="application/javascript" src="/tests/SimpleTest/SimpleTest.js"></script>
  <link rel="stylesheet" type="text/css" href="/tests/SimpleTest/test.css"/>
</head>
<body>
<a target="_blank" href="https://bugzilla.mozilla.org/show_bug.cgi?id=590353">Mozilla Bug 590353</a>
<p id="display"></p>
<div id="content" style="display: none">
</div>
<pre id="test">
<script type="application/javascript">

/** Test for Bug 590353 **/

var testData = [
  [ "text", "foo", "" ],
  [ "email", "foo@bar.com", "" ],
  [ "url", "http:///foo.com", "" ],
  [ "tel", "555 555 555 555", "" ],
  [ "search", "foo", "" ],
  [ "password", "secret", "" ],
  [ "hidden", "foo", "foo" ],
  [ "button", "foo", "foo" ],
  [ "reset", "foo", "foo" ],
  [ "submit", "foo", "foo" ],
  [ "checkbox", true, false ],
  [ "radio", true, false ],
  [ "file", "590353_file", "" ],
];

function createFileWithData(fileName, fileData) {
  return new File([new Blob([fileData], { type: "text/plain" })], fileName);
}

var content = document.getElementById('content');
var form = document.createElement('form');
content.appendChild(form);

for (var data of testData) {
  var e = document.createElement('input');
  e.type = data[0];

  if (data[0] == 'checkbox' || data[0] == 'radio') {
    e.checked = data[1];
  } else if (data[0] == 'file') {
    var file = createFileWithData(data[1], "file content");
    SpecialPowers.wrap(e).mozSetFileArray([file]);
  } else {
    e.value = data[1];
  }

  form.appendChild(e);
}

form.reset();

var size = form.elements.length;
for (var i=0; i<size; ++i) {
  var e = form.elements[i];

  if (e.type == 'radio' || e.type == 'checkbox') {
    is(e.checked, testData[i][2],
       "the element checked value should be " + testData[i][2]);
  } else {
    is(e.value, testData[i][2],
       "the element value should be " + testData[i][2]);
  }
}

</script>
</pre>
</body>
</html>
